## Button Debounce 電路設計

## 下圖為 Button Debounce 電路的 Waveform 圖



Fig. Button Debounce Waveform

其電路原理為利用 50MHz(20ns)的 system clock 產生間隔為 20ms 的 pulse 訊號,並以此訊號來 capture 按鈕的訊號,並避開按鈕 bounce 的時間,再利用 Edge detector 的電路設計方式產生一個 Pulse 訊號(data\_neg\_o)。所以每當按鈕 (button)被按下時,即會產生一個 pulse 訊號。

完整的 Verilog Code 如下所示:

```
module debounce (
 data_neg_o,
input
         clk, reset n;
input
output data_out;
output data_neg_o;
parameter time_20ms = 32'd49999 * 20;
reg [31:0] cnt; // counter to generate 20ms
           data in 1d, data in 2d;
wire
           time 20ms cap;
always@(posedge clk or negedge reset n)
begin
    else if(cnt == time 20ms)
            cnt <= cnt + 1'b1;
assign time 20ms cap = (cnt == time 20ms) ? 1'b1 : 1'b0;
always@(posedge clk or negedge reset n)
begin
    if(~reset_n) begin
        data_in_2d <= 1'b0;
    else if (time_20ms_cap) begin
    else begin
        data_in_2d <= data_in_2d;
assign data_neg_o = ~data_in_1d && data_in_2d;
```